import { getToken } from './auth';
import axios from 'axios'
import { message } from 'ant-design-vue';

// 创建axios实例
const service = axios.create({
  // 请求地址配置
  baseURL: process.env.VITE_APP_BASE_URL,
  // 超时
  timeout: 100000
})

// request拦截器
service.interceptors.request.use(config => {
  // 设置 token
  config.headers['Authorization'] = getToken()
  return config
}, error => {
  console.log(error)
  Promise.reject(error)
})

// 响应拦截器
service.interceptors.response.use(
  response => {
    const res = response.data
    if (res.status && res.status !== 0) {
      message.error(res.message, 2 * 1000)
      if (res.status === 500) {
        return Promise.reject('请求异常，请稍后再试！')
      }
    }
    return response.data
  },
  error => {
    console.log('err' + error)
    let { message } = error;
    message.error(error, 2 * 1000)
    return new Promise((reject) => {return reject(error)})
  }
)

export default service
